热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

联系地址|院校_智慧校园比赛系统Python+Django

篇首语:本文由编程笔记#小编为大家整理,主要介绍了智慧校园比赛系统-Python+Django相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了智慧校园比赛系统-Python+Django相关的知识,希望对你有一定的参考价值。




作者主页:编程指南针



 简介:Java领域优质创作者、CSDN博客专家  Java项目、简历模板、学习资料、面试题库、技术互助


文末获取源码


项目编号:BS-Python-002

1.项目说明


  • 项目名称:智慧答题系统
  • 项目版本:V 1.0
  • 版本变化:无
  • 完成日期:2022年1月20日

2.  系统环境

Windows或Linux发行版(Ubuntu16.04 / CentOS等)

mysql 5.5以上版本

Python3.5以上版本

Redis任意新版本即可

Django版本2.1

本项目基于Python+Django技术开发实现,开发工具IDEA,数据库MYSQL5.7

主要实现题库设置,比赛生成,在线答题,自动排名,自动组卷,自动改卷等相关功能。

下面展示一下系统的相关功能:

用户注册

登陆

快速出题

配置比赛

上传题库

参与比赛

开始作题

 

自动阅卷排名

修改个人密码

查看所有比赛

以上是智慧校园比赛系统的主要内容

系统部分核心代码:

# -*- coding: utf-8 -*-
from django.contrib.auth.models import User
from django.conf import settings
from django.db import transaction
from django.views.decorators.csrf import csrf_exempt
from account.models import Profile
from business.models import BusinessAccountInfo
from utils.response import json_response
from utils.errors import BizError, UserError
def check_biz(request):
email = request.GET.get('email', '') # 获取邮箱
try: # 检查数据库中是否由该邮箱注册过的数据
biz = BusinessAccountInfo.objects.get(email=email)
except BusinessAccountInfo.DoesNotExist:
biz = None
return json_response(200, 'OK', # 返回是否已经被注册过和是否已经有此用户
'userexists': User.objects.filter(email=email).exists(),
'bizaccountexists': bool(biz)
)
@csrf_exempt
@transaction.atomic
def registry_biz(request):
email = request.POST.get('email', '') # 获取填写的邮箱
name = request.POST.get('name', '') # 获取填写的机构名
username = request.POST.get('username', '') # 获取填写的机构联系人
phone = request.POST.get('phone', '') # 获取填写的手机号
ctype = request.POST.get('type', BusinessAccountInfo.INTERNET) # 获取机构类型
flag = int(request.POST.get('flag', 2)) # 获取一个标记位,代表用户是创建新用户还是使用绑定老用户的方式
uname = email.split('@')[0] # 和之前的注册逻辑没什么区别,创建一个账户名
if not User.objects.filter(username__exact=name).exists():
final_name = username
elif not User.objects.filter(username__exact=uname).exists():
final_name = uname
else:
final_name = email
if flag == 2: # 如果标记位是2,那么将为他创建新用户
user = User.objects.create_user(
username=final_name,
email=email,
password=settings.INIT_PASSWORD,
is_active=False,
is_staff=False
)
if flag == 1: # 如果标记位是1,那么为他绑定老用户
try:
user = User.objects.get(email=email)
except User.DoesNotExist:
return json_response(*UserError.UserNotFound)
pvalues =
'phone': phone,
'name': final_name,
'user_src': Profile.COMPANY_USER,

profile, _ = Profile.objects.select_for_update().get_or_create(email=email) # 获取或创建用户信息
for k, v in pvalues.items():
setattr(profile, k, v)
profile.save()
bizvalues =
'company_name': name,
'company_username': username,
'company_phone': phone,
'company_type': ctype,

biz, _ = BusinessAccountInfo.objects.select_for_update().get_or_create( # 获取或创建机构账户信息
email=email,
defaults=bizvalues
)
return json_response(200, 'OK', # 响应JSON格式数据,这个标记位在发送验证邮件的时候还有用
'name': final_name,
'email': email,
'flag': flag
)

# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import models
from django.utils.translation import ugettext_lazy as _
from shortuuidfield import ShortUUIDField
from utils.basemodels import CreateUpdateMixin
class BusinessAccountInfo(CreateUpdateMixin):
""" 出题帐户类 """
INTERNET = 0
FINANCE = 1
ENERGY = 2
INFRASTRUCTURE = 3
TRANSPORTATION = 4
COMMUNICATION = 5
TYPE_CHOICES = (
(INTERNET, '互联网'),
(FINANCE, '金融'),
(ENERGY, '能源'),
(INFRASTRUCTURE, '基础建设'),
(TRANSPORTATION, '交通'),
(COMMUNICATION, '通信')
)
account_id = ShortUUIDField(_(u'出题账户id'), max_length=32, help_text=u'出题账户唯一标识', db_index=True)
# 帐户信息
email = models.CharField(_(u'邮箱'), max_length=40, blank=True, null=True, help_text=u'邮箱', db_index=True, unique=True)
# 公司信息
company_name = models.CharField(_(u'公司名称'), max_length=60, blank=True, null=True, help_text=u'公司名称')
company_type = models.IntegerField(_(u'公司类型'), choices=TYPE_CHOICES, default=INTERNET, help_text=u'公司类型')
company_description = models.TextField(_(u'公司描述'), blank=True, null=True, help_text=u'公司描述')
company_username = models.CharField(_(u'联系人'), max_length=32, blank=True, null=True, help_text=u'公司联系人')
company_phone = models.CharField(_(u'联系电话'), max_length=16, blank=True, null=True, help_text=u'公司联系电话', db_index=True)
company_location = models.TextField(_(u'公司位置'), blank=True, null=True, help_text=u'公司联系地址')
class Meta:
verbose_name = _(u'出题账户')
verbose_name_plural = _(u'出题账户')
def __unicode__(self):
return str(self.pk)
@property
def data(self):
return
'email': self.email,
'company_name': self.company_name,
'company_type': self.company_type,
'company_location': self.company_location,
'company_username': self.company_username,
'company_phone': self.company_phone,

class BusinessAppInfo(CreateUpdateMixin):
""" 应用信息类 """
account_id = models.CharField(_(u'出题账户id'), max_length=32, help_text=u'出题账户唯一标识', db_index=True)
# APP 配置信息
app_id = ShortUUIDField(_(u'应用id'), max_length=32, help_text=u'应用唯一标识', db_index=True)
app_name = models.CharField(_(u'应用名'), max_length=40, blank=True, null=True, help_text=u'应用名')
app_description = models.TextField(_(u'应用描述'), blank=True, null=True, help_text=u'应用描述')
class Meta:
verbose_name = _(u'应用信息')
verbose_name_plural = _(u'应用信息')
def __unicode__(self):
return str(self.pk)
@property
def data(self):
return
'app_id': self.app_id,
'app_name': self.app_name,
'account_id': self.account_id,

class AppConfigInfo(CreateUpdateMixin):
""" 应用配置信息类 """
app_id = models.CharField(_(u'应用id'), max_length=32, help_text=u'应用唯一标识', db_index=True)
app_name = models.CharField(_(u'应用名'), max_length=40, blank=True, null=True, help_text=u'应用名')
# 文案配置
rule_text = models.TextField(_(u'比赛规则'), max_length=255, blank=True, null=True, help_text=u'比赛规则')
# 显示信息
is_show_userinfo = models.BooleanField(_(u'展示用户表单'), default=False, help_text=u'是否展示用户信息表单')
userinfo_fields = models.CharField(_(u'用户表单字段'), max_length=128, blank=True, null=True, help_text=u'需要用户填写的字段#隔开')
userinfo_field_names = models.CharField(_('用户表单label'), max_length=128, blank=True, null=True, help_text=u'用户需要填写的表单字段label名称')
option_fields = models.CharField(_(u'下拉框字段'), max_length=128, blank=True, null=True, help_text=u'下拉框字段选项配置,#号隔开,每个字段由:h和,号组成。 如 option1:吃饭,喝水,睡觉#option2:上班,学习,看电影')
class Meta:
verbose_name = _(u'应用配置信息')
verbose_name_plural = _(u'应用配置信息')
def __unicode__(self):
return str(self.pk)
# 页面配置数据
@property
def show_info(self):
return
'is_show_userinfo': self.is_show_userinfo,
'userinfo_fields': self.userinfo_fields,
'userinfo_field_names': self.userinfo_field_names,
'option_fields': self.option_fields,

@property
def text_info(self):
return
'rule_text': self.rule_text,

@property
def data(self):
return
'show_info': self.show_info,
'text_info': self.text_info,
'app_id': self.app_id,
'app_name': self.app_name

class UserInfoImage(CreateUpdateMixin):
"""
用户表单图片配置类
"""
uii_name = models.CharField(_(u'配置名称'), max_length=32, blank=True, null=True, help_text=u'信息图片配置名称')
# 用户信息
name = models.CharField(_(u'姓名'), max_length=60, blank=True, null=True, help_text=u'姓名')
sex = models.CharField(_(u'性别'), max_length=60, blank=True, null=True, help_text=u'性别')
age = models.CharField(_(u'年龄'), max_length=60, blank=True, null=True, help_text=u'年龄')
phone = models.CharField(_(u'手机号'), max_length=60, blank=True, null=True, help_text=u'电话')
wxid = models.CharField(_(u'微信号'), max_length=60, blank=True, null=True, help_text=u'微信号')
email = models.CharField(_(u'邮箱'), max_length=60, blank=True, null=True, help_text=u'邮箱')
pid = models.CharField(_(u'身份证号'), max_length=60, blank=True, null=True, help_text=u'身份证号')
graduated_from = models.CharField(_(u'毕业院校'), max_length=60, blank=True, null=True, help_text=u'毕业院校')
address = models.CharField(_(u'地址'), max_length=60, blank=True, null=True, help_text=u'联系地址')
resume = models.CharField(_(u'简历'), max_length=60, blank=True, null=True, help_text=u'简历')
class Meta:
verbose_name = _(u'用户信息图片配置')
verbose_name_plural = _(u'用户信息图片配置')
def __unicode__(self):
return str(self.pk)
@property
def data(self):
return
'name': self.name,
'sex': self.sex,
'age': self.age,
'phone': self.phone,
'wxid': self.wxid,
'email': self.email,
'pid': self.pid,
'graduated_from': self.graduated_from,
'address': self.address,

class UserInfoRegex(CreateUpdateMixin):
"""
用户正则表达式配置类
"""
field_name = models.CharField(_(u'字段名'), max_length=16, blank=True, null=True, help_text=u'字段名')
regex = models.CharField(_(u'正则表达式值'), max_length=40, blank=True, null=True, help_text=u'正则表达式')
description = models.CharField(_(u'description'), max_length=40, blank=True, help_text=u'错误描述')
class Meta:
verbose_name = _(u'用户信息字段正则表达式')
verbose_name_plural = _(u'用户信息字段正则表达式')
def __unicode__(self):
return self.field_name
@property
def data(self):
return
'field_name': self.field_name,
'regex': self.regex,
'description': self.description,


# -*- coding: utf-8 -*-
from django.contrib import admin
from competition.models import (BankInfo, ChoiceInfo, CompetitionKindInfo,
CompetitionQAInfo, FillInBlankInfo)
class CompetitionKindInfoAdmin(admin.ModelAdmin):
"""
比赛信息后台
"""
list_display = ('kind_id', 'account_id', 'app_id', 'bank_id', 'kind_name', 'total_score', 'question_num', 'total_partin_num', 'status', 'created_at', 'updated_at')
list_filter = ('account_id', 'status')
search_fields = ('kind_name', 'kind_id', 'app_id', 'account_id',)
readonly_fields = ('kind_id', 'total_partin_num',)
def save_model(self, request, obj, form, change):
obj.save()
def delete_model(self, request, obj):
obj.delete()
def get_readonly_fields(self, request, obj=None):
return self.readonly_fields
class BankInfoAdmin(admin.ModelAdmin):
"""
题库后台配置
"""
list_display = ('bank_id', 'bank_type', 'kind_num', 'choice_num', 'fillinblank_num', 'partin_num')
list_filter = ('bank_type', 'bank_id',)
search_fields = ('bank_id',)
readonly_fields = ('bank_id', 'choice_num', 'fillinblank_num', 'kind_num', 'partin_num')
def save_model(self, request, obj, form, change):
obj.choice_num = ChoiceInfo.objects.filter(bank_id=obj.bank_id).count()
obj.fillinblank_num = FillInBlankInfo.objects.filter(bank_id=obj.bank_id).count()
obj.save()
class ChoiceInfoAdmin(admin.ModelAdmin):
"""
选择题配置后台
"""
list_display = ('bank_id', 'question', 'answer', 'item1', 'item2', 'item3', 'item4', 'source', 'status', 'created_at', 'updated_at')
list_filter = ('bank_id', 'status')
search_fields = ('bank_id', 'question', 'answer', 'item1', 'item2', 'item3', 'item4')
def save_model(self, request, obj, form, change):
obj.save()
def delete_model(self, request, obj):
obj.delete()
class FillInBlankInfoAdmin(admin.ModelAdmin):
"""
填空题配置后台
"""
list_display = ('bank_id', 'question', 'answer', 'source', 'status', 'created_at', 'updated_at')
list_filter = ('bank_id', 'status')
search_fields = ('bank_id', 'question', 'answer')
class CompetitionQAInfoAdmin(admin.ModelAdmin):
"""
答题记录信息后台
"""
list_display = ('kind_id', 'status', 'uid', 'qa_id', 'score', 'created_at', 'updated_at')
list_filter = ('kind_id', 'uid', 'qa_id', 'started', 'finished', 'status')
search_fields = ('uid', 'kind_id', )
readonly_fields = ('qa_id',)
admin.site.register(CompetitionKindInfo, CompetitionKindInfoAdmin)
admin.site.register(CompetitionQAInfo, CompetitionQAInfoAdmin)
admin.site.register(ChoiceInfo, ChoiceInfoAdmin)
admin.site.register(FillInBlankInfo, FillInBlankInfoAdmin)
admin.site.register(BankInfo, BankInfoAdmin)


推荐阅读
  • Centos下安装memcached+memcached教程
    本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • Python项目实战10.2:MySQL读写分离性能优化
    本文介绍了在Python项目实战中进行MySQL读写分离的性能优化,包括主从同步的配置和Django实现,以及在两台centos 7系统上安装和配置MySQL的步骤。同时还介绍了创建从数据库的用户和权限的方法。摘要长度为176字。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • github上_idea上传本地项目到github上(图解)
    本文由编程笔记#小编为大家整理,主要介绍了idea上传本地项目到github上(图解)相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 成功安装Sabayon Linux在thinkpad X60上的经验分享
    本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • Vagrant虚拟化工具的安装和使用教程
    本文介绍了Vagrant虚拟化工具的安装和使用教程。首先介绍了安装virtualBox和Vagrant的步骤。然后详细说明了Vagrant的安装和使用方法,包括如何检查安装是否成功。最后介绍了下载虚拟机镜像的步骤,以及Vagrant镜像网站的相关信息。 ... [详细]
  • centos安装Mysql的方法及步骤详解
    本文介绍了centos安装Mysql的两种方式:rpm方式和绿色方式安装,详细介绍了安装所需的软件包以及安装过程中的注意事项,包括检查是否安装成功的方法。通过本文,读者可以了解到在centos系统上如何正确安装Mysql。 ... [详细]
  • 本文介绍了在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一,尤其是在大规模系统中,数据库集群已经成为必备的配置之一。文章详细介绍了主从数据库架构的好处和实验环境的搭建方法,包括主数据库的配置文件修改和设置需要同步的数据库等内容。MySQL的主从复制功能在国内外大型网站架构体系中被广泛采用,本文总结了作者在实际的Web项目中的实践经验。 ... [详细]
author-avatar
美多小涛_584
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有